<script setup lang="ts">
import { useRouter } from 'vue-router'
const props = defineProps<{
  title?: string
  rightText?: string
  back?: () => void
}>()

const emit = defineEmits<{
  (e: 'click-right'): void
}>()

//1. 一定有的功能：返回图标，返回效果，固定定位（组件内部实现）
const router = useRouter()

const onClickLeft = () => {
  // 如果传的back  就不走后退首页
  if (props.back) return props.back()

  // 判断历史记录中是否有回退
  if (history.state.back) {
    router.back()
  } else {
    router.push('/')
  }
}



// 2. 使用组件时候才能确定的功能：标题，右侧文字，点击右侧文字行为（props传入）
const onClickRight = () => {
  emit('click-right')
}
</script>

<template>
  <van-nav-bar fixed left-arrow :title="title" :right-text="rightText" @click-left="onClickLeft"
    @click-right="onClickRight"></van-nav-bar>
</template>

<style lang="scss" scoped>
::v-deep() {
  .van-nav-bar {
    &__arrow {
      font-size: 18px;
      color: var(--cp-text1);
    }

    &__text {
      font-size: 15px;
    }
  }
}
</style>
